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(57) An apparatus for firmware authentication and 
methods of operating the same result in software up- 
gradability to firmware without compromising the integ- 
rity of the firmware. The apparatus for firmware authen- 
tication of a boot PROM comprises a software program- 



mable data section having a plurality of micro-code. An 
authentication section having a hash generator config- 
ured to generate* a data hash tn response to the plurality 
of micro-code programmed in the software programma- 
ble data section to authorize execution of the plurality 
of micro-code of the data section. 
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Description 

The present invention relates to authentication of 
firmware (for example, programmed micro-code such 
as programmable micro-code written in a memory de- 5 
vice). 

Computer systems durinq initial power up rely on a 
sequence of instructional routines which build on each 
previously executed instructional routine until the com- 
puter system is initialized. Micro-code, also referred to 
as firmware or boot code, is the first level of the instruc- 
tional routines that are executed when the computer 
system is initially powered up. The micro<ode stored in 
non-volalile menrwry devices such as a memory IC (in- 
tegrated circuit) directs the computer system to certain 
boot blocks located on a disk drive . As these boot blocks 
on the disk drive are executed, successively larger 
blocks of boot data are loaded untit finally the operating 
system^ such as an Unix or Microsoft Windows of the 
computer system is loaded. 

The micro-code for the initial boot up instructions of 
a computer system is typically stored in a boot ROM 
(read only memory) or boot PROM (programmable read 
only memory). An example of a PROM is a flash PROM, 
often referred to as flash memory. Needs arise when the 
micro-code for the initial boot up instnjctions requires 
updating. Those computer systems having ROMs re- 
quire new ROMs. Replacing old ROfs^ with newly sup- 
plied ROMs is expensive. Furthermore, the computer 
system has to be disassembled to gain access to re- 
place the ROMs. 

In computer systems with boot PROMs that employ 
flash technology, updating new micro-code entails ac- 
cessing the flash PROM using software and progranri- 
ming the flash PROM with new micro-code. However, 
because the micro-code contained in the boot PROM is 
the first code that is executed, reasons to limit program- 
ming access to the flash PROM include: 1) inadvertent 
programming can cause the computer system become 
compietely inactive; 2) security sensitive environments 
require that the micro-code be tamper-proof to prevent 
security risks. Thus, safeguards are currently in place 
to prevent modificatkxi of the boot PROM. 

These safeguards include using boot ROMs to store 
the micro-code or setting hardwire jumpers that prevent 
software modification of boot PROMs. In order to modify 
the micro-code, bool ROMs must be replaced with new 
boot ROMs containing the updated micro-code. In the 
case of boot PROMs, user intervention is required to 
manually switch the jumpers of the boot PROMs to en- 
able programming access to the boot PROMs for the 
new micro-code. In either case, user intervention is re- 
quired to physically open the computer system and 
make the necessary changes. The changes range from 
the replacement of old boot ROMs with new boot ROMs 
to changing jumper settings of the flash boot PROM to 
enable and disable programming of the flash boot 
PROM. Thus, the safeguards require additional time 



and effort from the users to implement modifications to 
the micro-code. The process of providing upgrades to 
the micro-code programming is cumbersome and time- 
consuming. 

Therefore, it is desirable to provide an apparatus for 
authenticating firmware programmed in a boot PROM 
and methods of operating the same that enable pro- 
gramming access to the boot PROM without compro- 
mising the authentbity of the firmware that overcome 
the disadvantages of disassembling the computer sys- 
tem. 

Various respective aspects and features of the in- 
vention are defined in the appended claims. 

The present invention provides an apparatus for 
firmware authentication and methods for operating the 
same which result in software upgradability to firmware 
without compromising the integrity of the firmware. The 
novel application for authentication of firmware is based 
on cryptography. Thus, according to one aspect of the 
invenlion. a boot PROM (programmable readonly mem- 
ory) having programming instructions for initiating a 
computer system is provided. A software programmable 
data section has a plurality of micro-code. An authenti- 
cation section having a hash generator generates a data 
hash in response to the plurality of micro-codo pro- 
grammed in the software programmable data section to 
authorize execution of the plurality of micro-code of the 
data section. 

According to another aspect of the invention, the 
software programmable data section includes a prede- 
termined digital signature, and the authentication sec- 
tion includes a predetermined public key and a decryp- 
tor which provides an verification hash in response to 
the predetenmined signature and the publb key. The au- 
thentication section also includes a comparator whbh 
compares the data hash with the verification hash to au- 
thenticate the plurality of micro-code of the software pro- 
grammable data section. If the data hash and the veri- 
fication hash do not match, a message alerts the user 
of the mismatch indicating tfiat the micro-code is not au- 
thenticated. 

According to another aspect of the invention, the 
authenticatkxi sectk)n includes a plurality of trusted mi- 
cro-code which initiates execution of the plurality of mi- 
cro-code of the software programmable data section in 
response to proper authentbatkHi of the data hash. The 
proper authentication of the data hash by the authenti- 
cation section of the plurality of trusted mrcro-code af- 
fords the plurality of micro-code programmed In the soft- 
ware programnnable data section to a level of trusted 
code. Thus, the trusted code of the software program- 
mable data section can be used to authenticate another 
sot of downstream code that is executed during the boot 
up sequence for the computer system. 

According to yet another aspect of the invention, the 
software programmable data section includes a flash 
memory whk^ enables software reprogramming of the 
plurality of micro-code. Other programmable storage 
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mediums are also usable for the storage of the micro- 
code. The authentication section includes a ROM (read 
only memory) that provides a base line for trusted code. 

An apparatus and melhod tor firmware authentica- 
tion are provided by authenticating the software pro- 
grammable data section of the boot PROM with a trust- 
ed ROM section of the boot PROM. The ability to provide 
software programmability of the boot PROM affords 
ease in upgradability that saves time, effort, and energy. 
Upgrading with newer vereions of the boot PIROM af- 
fords support for new functions and eliminates bugs and 
other inconsistencies that can plague older versions of 
the boot PROM. Thus, the newer boot PROMs provide 
for a smoother and more efficient operating computer 
system. 

The invention will now be described by way of ex- 
ample with reference to the accompanying drawings, 
throughout which like parts are referred to by liKe refer- 
ences, and in which: 

Fig. 1 Illustrates a system level block diagram of a 
computer system; 

Fig. 2 illustrates a block diagram of a flash PROM 
of the computer system in accordance with the 
present invention; 

Fig. 3 illustrates a flow diagram for generating a sig- 
nature in accordance with the present invention; 
and 

Fig. 4 illustrates a flow diagram for authenticating 
unsecured micro-code of the programmable sec- 
tion of the flash PROM. 

Embodiments of the invention will now be described 
with respect to tfie figures in which Fig. 1 generally 
shows a simplified computer system 10. The computer 
system 10 includes a CPU (central processing unit) 12, 
display 14, hard disk 16 and a flash PROM (program- 
mable read-only memory) 18. The computer system 10 
is for illustrative purposes as many variations to (he ar- 
chitecture of the computer system 10 are available and 
known in the art. CPU bus 22 couples the CPU 12 to 
data bus 13. The CPU 12 includes a memory 15 v^rtiich 
stores instructons and data for processing by the CPU 
12. Disk drive bus 26 couples the disk drive 16 to the 
data bus 1 3. The disk drive 1 6 provktes non-volatile data 
storage lor the computer system 10. Data transfers oc- 
cur between the CPU 12 and the disk drive 12 as the 
data is processed by CPU 12. Display bus 24 couples 
the display 14 to the data bus 13. The display 14 re- 
ceives output data for display. The display 14 includes 
a keyboard 17 coupled to the display via cable 19. The 
keyboard 1 7 provides an user interface to computer sys- 
tem 10. PROM bus 28 couples the flash PROM 18 to 
data bus 13. The flash PROM IB includes initialization 
instructions for the computer system 10. 

During start-up of the computer system 10. micro- 
code instructions stored in the flash PROM 18 are exe- 
cuted. The mk;ro-code instruct bns include boot code 
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that directs execution of particular boot blocks of the 
hard disk 16. Once the instructions contained in the boot 
blocks of the hard disk 16 are executed and loaded into 
the memory 15, higher level instructions and code are 
5 executed and loaded into memory 1 5 such as operating 
systems for Windows 95. Unix, or Macintosh based 
computers. The higher level instructions and code may 
be executed from a network sen/er. Thus. In an alterna- 
tive embodiment, computer system 10 is one of a 
10 number of computer systems coupled to a network. 

In a network, the computer system lO may not in- 
clude the disk drive 16, as data transfers are through a 
network server. The network server includes wired net- 
work connections, RF (radio frequency) network con- 
is nections, and IR (infrared) network connections. Other 
computer systems include hand held systems such as 
PDAs (Personal Data Assistants) and computer sys- 
tems that include micro-code to initialize the computer 
system. 

20 Fig. 2 illustrates a block diagram of the flash PROM 
18. The flash PROM 18 is divkied into two main sec- 
tions: a authentication section 45 and a programmable 
section 55. The authentication section 45 rs a ROM 
(read-only memory). The micro-code instructk>ns con- 

2S tained in the authentication section 45 are read-only. 
The micro-code instructions contained in the program- 
mable section 55 are re- writable. For example, the pro- 
grammable section 55 includes a flash memory that is 
software programmable with new micro-code. 

30 The authentication section 45 authenticates the 
programmable section 55 to verify that the microKXxje 
instmctions which boot the computer system 10 are 
trusted because the programmable section 55 is soft- 
ware programmable. The authenticatk>n sectkm 45 in- 

3S dudes a plurality of secure micro-code 51 , a comparator 
52, a hash generator 53. a decryptor 54 and a public 
key 56. The unsecured sectk>n 55 ir^iudes a digital sig- 
nature 57 and a plurality of unsecured micro-code 58. 
During initiaUzatton of the computer system 10. the 

40 secure micro-code 51 of the authentication section 45 
executes and directs the hash generator 53 to generate 
a data hash of the unsecured micro-code 58 pro- 
grammed in the programmable section 55 of the flash 
PROM 18. The secure micro-code 51 also directs the 

^ decryptor 64 to calculate a verification hash. The de- 
cryptor applies the public key 56 of the authentication 
section 45 and the digital signature 57 of the program- 
mable secUon 55 and cateulates the verificalkxi hash. 
Once the verification hash and the data hash are 

so generated, the micro-code 51 directs the comparator 52 
to compare the verification hash with the data hash. If 
the verification hash matches the data hash, the unse- 
cured micro-code 55 is properly verified and permitted 
to execute. If the comparison of the verification hash and 

55 the data hash fails, the unsecured micro-code 58 is cor- 
rupted or had-been altered without proper authorization. 

Publk;-key cryptography verifies that the digital sig- 
nature 57 and the public key 56 decrypts to a verification 
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hash which matches the data hash of the micro-code 
programmed in Ihe programmable section 55 of the 
flash PROM 18. The data hash generator 53 generates 
the data hash. A digital signature 57 of the programma> 
ble section 56 is provided when the programmable sec- 
tion 55 is programmed. During authorized programming 
of the programmable section 55. an initial hash from the 
authorized programming micro-code is generated. 
Next, a proper digital signature 57 is encrypted from a 
secret key and the initiaf hash of the authorized pro- 
gramming micro-code 58 using public key cryptography 
techniques. The proper digital signature 57 and the au- 
thorized programming micro-code 58 are written to the 
programmable section 55. 

The authentication section 45 of the flash PROM 18 
is initially programmed with the secure micro-code 51 . 
the comparator 52. the hash generator 53. the decryptor 

54, and the publto key 56. Whenever the computer sys- 
tem 10 is inrttalized, the authentication section 45 veri- 
fies that the data hash of the unsecured micro-code 58 
matches the verification hash to ensure the Integrity of 
the unsecured micro-code 58 and authentk^ate that the 
unsecured micro-code 58 had not beert altered. As the 
unsecured micro-code 58 of the programmable section 
55 is authenticated, the trust tevGl of the unsecured mi- 
cro-cod© 68 is raised to a level of trusted. Thus, the au- 
thenticated micro-code 58 can be used to authenticate 
other initialization code down stream in the start-up se- 
quence of the computer system 10. 

Fig. 3 shows a fk)w diagram for generating a digital 
signature 57 for the mfcro-code 58. The diagram begins 
with generation of the verification hash from the mcro- 
code 58 in step 62. Next, the private key is obtained for 
the generation of a verification hash from the mk:ro-code 
58 in step 64. In step 66. the verification hash is encrypt- 
ed using publk; key cryptography lechnques and the pri- 
vate key to obtain the digital signature 57. Finally, in step 
68, the digital signature 57 is programmed with the mi- 
cro-code 58 to the programmable sectbn 55 of the flash 
PROM 18. 

Fig. 4 shows a flow diagram for authentrcaling the 
unsecured micro-code 58 of the programmable section 

55. The diagram begins with generation of the data hash 
from the unsecured micro-code 58 contained in the pro- 
grammable section 55 m step 72. In step 73, the verifi- 
cation hash is decrypted with the public key 56 con- 
tained in the authentication section 45 and the digital 
signature 57 contained in the programmable section 55. 
Step 74 provides a comparison of the verification hash 
with the data hash. In decision step 75, if the verification 
hash matches the data hash then step 77 authorizes the 
execution of the micro-code 58 contained in the pro- 
grammable section 55. If in decision step 75. the verifi- 
cation hash does not match the data hash; step 78 pro- 
vides a message to the user that an error occurred dur- 
ing authentication of the programmable section 55 and 
offers a recovery solutk^n for the user to obtain valid mi- 



A flash PROM 18 having an authentication section 
45 and a programmable section 55 affords ease in up- 
dating the flash PROM 18 with new micro-code without 
compromising security. Implementing public-key cryp- 

s tography having a private key and a public key to verify 
the programmable section 55 with the authentication 
section 45 assures that the programmable section of the 
micro-code is proper and authentk:. The integrity of the 
unsecured mk:ro-code 58 of the programmable section 

10 55 is also verified when the verification hash matches 
the data hash. As the trust level of the unsecured micro- 
code 58 is raised to a level of trusted, other boot data 
such as the boot blocks of the disk drive 16 used for 
initializing the computer system 10 can be similarly au- 

is thenticated using the now trusted micro-code 58 of the 
programmable section 55. Thus, a propagation of a se- 
ries of security checks during the boot-up sequence can 
t>e implemented to* ensure that each sequence executes 
properly authenticated boot code 

20 While the foregoing detailed descriplk>n has de- 
scribed several embodiments of the apparatus arKi 
methods of firmware authentk:alion in accordance with 
this invention, it is to be understood that the above de- 
scription is illustrative only and not limiting of the dis- 

2S closed invention. Obviously, many modifications and 
variations will be apparent to the practitioners skilled in 
this art. Accordingly, the apparatus and methods of 
firmware authentication has been provided which au- 
thenticates the programmable sectk)n of a flash PROM 

30 with a read-only section of the flash PROM by applk:a- 
tion of public-key cryptography. By affording a program- 
mable section of the flash PROM to be software pro- 
grammable, updates to the firmware are accomplished 
without compromising the integrity of the firmware. No 

35 longer are system operators required to disassemble 
computer systems to perform updates to system start- 
up firmware. 

Particular and preferred aspects of the inventk>n are 
set out in the accompanying independent and depend- 
40 ent claims. Features of the dependent claims may be 
combined with those of the independent claims as ap- 
propriate and in combinations other than those explicitly 
set out in the claims. 

45 

Claims 

1. A boot PROM (programmable read only memory) 
having programming instructbns for initiating a 
50 computer system comprising: 

a software programmable data section having 
a plurality of micro-code; and 
an authenticatk^n sectk>n having a hash gener- 
ss ator configured to generate a data hash in re- 

sponse to the plurality of microK^ode pro- 
grammed in the software programmable data 
section to authorize execution of the plurality of 
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micro-code of the data section. 10. The method of operating a boot PROM according 

to claim 9, wherein the software programmable data 
2. The boot PROM according to ciaim 1 . wherein: section includes a predetermined signature and the 

step of authenticating includes decrypting a verifi- 
the software programmable data section in- s cation hash in response to the predetermined sig- 
cludes a oredetermined sionature; and nature and a public key. 



the authentication section Includes a predeter- 
mined public key and a decryptor configured to 
provide an verification hash in response to the 
predetermined signature and the public key. 



3. The boot PROM according to claim 2, wherein the 
authentication section includes a comparator con- 
figured to compare the data hash with the verifica- 
tion hash to authenticate the plurality of micro-code 
of the software programmable data section. 

4. The boot PROM according to claim 2. wherein the 
predetemiined signature includes an encryption of 
a private key and an initial hash of a plurality of initial 
micro-code programmed to the software program- 
mable data section. 

5. The boot PROM according to claim 1 , wherein the 
authentication section includes a plurality of trusted 
micro-code configured to initiate executksn of the 
plurality of micro-code of the software programma- 
ble data section in response to proper authentica- 
tion of the data hash. 

6. The boot PROM according to claim 5, wherein the 
proper authentication of the data hash by the au- 
thenticatksn section of the plurality of trusted micro- 
code affords the plurality of micro-code pro- 
grammed in the software programmable data sec- 
tion to a level of trusted code. 

7. The boot PROM according to claim 1, wherein the 
software programmable data section includes a 
flash memory configured to enable software repro- 
gramming of the pluiality of micro-code. 



11. The method of operating a boot PROM according 
to claim 1 0. wherein the step of authenticating in- 
cludes comparing the data hash with the verification 
hash to authenticate the plurality of micro-code of 
the software programmable data section. 

12. The method of operating a boot PROM according 
IS to claim 1 0 further comprising the step encrypting a 

private key and an initial hash of a plurality of initial 
micro-code programmed to the software program- 
nnable data sectkm to provide the predetermined 
signature. 

20 

13. The method of operating a boot PHOM according 
to claim 9. wherein the authentk:atkxi section in- 
cludes a plurality of trusted micro-code further com- 
prises the step of propagating a level of trusted code 

2S to the plurality of micro-codo of the software pro- 
grammable data section in response to proper au- 
thentication of the data hash. 

14. The method of operating a boot PROM according 
30 to daim 9 wherein the software programmable data 

section includes a flash memory further comprises 
the step of reprogramming the plurality of micro- 
code in the software programmable data sectbn. 

3S IS. The method of operating a boot PROM according 
to claim 9 wherein the authentteation section in- 
cludes a ROM (read only rTienrK>ry). 

16. A computer initialization system having a plurality 
40 of micro-code to initiate the computer system com- 
prising: 

a hard disk having a plurality of storage bk>cks 
configured to store programming data and ini- 
tializing boot data; 

a CPU (central processing unit) coupled to the 
hard disk configured to process programing da- 
ta from the hard disk; 

a display device coupled to the CPU and the 
hard disk configured to receive display data 
from the CPU and the hard disk; and 
a boot PROM (programmable read only mem- 
ory) coupled to the hard disk having a software 
programmable data section including the plu- 
rality of micro-code and an authentication sec- 
tion including a hash generator configured to 
generate a data hash in response to the plural- 
ity of micro-code programmed in the software 



The boot PROM according to claim 1 , wherein the 
authenticatk}n sectk>n trKludes a ROM (read only 
memory). 

A method of operating a boot PROM (progrannma- 
ble read only memory) having programming instruc- 
tions for initiating a computer system comprising the 
steps: so 

generating a data hash in response to a plural- 
ity of micro-code programmed in a software 
programmable data section; and 
authenticating the data hash in an authentica- ss 
tion section to authorize execution of the plu- 
rality of micro-code of the software programma- 
ble data section. 
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programmable to authorize execution of the 
plurality of micro-code of the data section for 
directing the initializing boot data of the hard 
disk to execute. 

5 

17. The computer initialization system according to 
claim 16. wherein: 

the software programmable data section of the 
boot PROM includes a predetermined signa- 
ture; and 

the authentication section of the boot PROM in- 
cludes a predetermined public key and a de- 
cryptor configured to provide an verificairan 
hash in response to the predetermined signa- is 
ture and the public key. 

18. The computer initial izatk>n system according to 
claim 17. wherein the authenticatton sectk)n in- 
cludes a comparator configured to compare the da- 
ta hash with the verification hash to authenticate the 
plurality of micro-code of the software prograrrmna- 
ble data section. 

19. The computer inrtializatran system according to 
claim 16, wherein the predetermined signature in- 
cludes a encryption of a private key and an initial 
hash of a plurality of initial micro-code programmed 
to the software programmable data sectbn. 

30 

20. The computer initialization system according to 
claim 19, wherein the proper authentication of the 
data hash by the authentication section of the plu- 
rality of trusted micro-code affords the plurality of 
mk:ro-code programmed in the software program- ss 
mable data section to a level of trusted code. 
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